

WHAT IS CLAIMED IS:

1. A delay equalizer for balancing clock signals in a clock tree, comprising:

a register operable to:

5 receive a divided input clock signal;  
receive a non-divided input clock signal; and  
generate a first output clock signal based on the received divided input clock signal and the received non-divided input clock signal, the first output clock signal being associated with a first delay;

10 a delay line operable to:

receive the non-divided input clock signal;  
delay the non-divided input clock signal for a time substantially equivalent to the first delay associated with the first output clock signal; and  
generate a second output clock signal being associated with a second delay substantially equal to the first delay of the first output signal; and

15 a multiplexer operable to:

receive the first output clock signal and the second output clock signal;  
receive a select control signal indicating which of the first output clock signal or the second output clock signal to select;  
select either the received first output clock signal or the second output clock signal based on the select control signal; and  
generate the selected first output clock signal or second output clock signal as a substantially balanced third output clock signal.

2. The delay equalizer of Claim 1, wherein:

the divided clock in signal being associated with a functional mode of a device comprising the delay equalizer; and

the select control signal received by the multiplexer comprises a divided/non-divided select control signal;

the delay equalizer is operable to substantially balance the input clock signal between one or more functional modes of the device.

3. The delay equalizer of Claim 2, wherein the delay equalizer is implemented at the output of existing clock dividing and selection logic.

4. The delay equalizer of Claim 2, wherein the delay equalizer is implemented within existing clock dividing and selection logic, the clock dividing and selection logic being redesigned to include the delay equalizer.

5. The delay equalizer of Claim 1, wherein the delay equalizer is associated with a clock-gating cell and is operable to provide the substantially balanced third output clock signal to the clock-gating cell as an input clock signal to the clock-gating cell such that an output clock signal generated by the clock-gating cell is substantially balanced.

6. The delay equalizer of Claim 1, wherein:

the register comprises a flip-flop register; and

the delay line comprises one or more buffers for delaying the non-divided clock signal.

7. A method for balancing clock signals in a node of a clock tree, comprising:

receiving a divided input clock signal at a register;

receiving a non-divided input clock signal at the register;

5 generating at the register a first output clock signal based on the received divided input clock signal and the received non-divided input clock signal, the first output clock signal being associated with a first delay;

receiving the non-divided input clock signal at a delay line;

delaying at the delay line the non-divided input clock signal for a time substantially equivalent to the first delay associated with the first output clock signal;

10 generating at the delay line a second output clock signal being associated with a second delay substantially equal to the first delay of the first output signal;

generating at a multiplexer the first output clock signal and the second output clock signal;

15 receiving at the multiplexer a select control signal indicating which of the first output clock signal or the second output clock signal to select;

selecting at the multiplexer either the received first output clock signal or the second output clock signal based on the select control signal; and

20 generating the selected first output clock signal or second output clock signal as a substantially balanced third output clock signal.

8. The method of Claim 7, wherein:

the divided clock in signal being associated with a functional mode of a device comprising the delay equalizer; and

25 the select control signal received by the multiplexer comprises a divided/non-divided select control signal;

the method substantially balancing the input clock signal between one or more functional modes of the device.

9. The method of Claim 8, wherein the method is performed on the output of existing clock dividing and selection logic.

5 10. The method of Claim 8, wherein the method is integrated into existing clock dividing and selection logic, the clock dividing and selection logic having been redesigned for implementing the method.

10 11. The method of Claim 7, further comprising providing the substantially balanced third output clock signal to a clock-gating cell as an input clock signal to the clock-gating cell such that an output clock signal generated by the clock-gating cell is substantially balanced.

15 12. The method of Claim 7, wherein:  
the register comprises a flip-flop register; and  
the delay line comprises one or more buffers for delaying the non-divided clock signal.

13. A method for balancing one or more clock signals in a clock tree having a multi-mode clock distribution, comprising:

associating a first delay equalizer with at least one of a plurality of clock-gating cells arranged in one or more levels in the clock tree, the first delay equalizer operable to provide a balanced input clock signal to the clock-gating cell such that an output clock signal generated by the clock-gating cell is substantially balanced;

10 associating a second delay equalizer with each of one or more clock-dividing and selection modules in the clock tree, the second delay equalizer operable to substantially balance the one or more clock signals between one or more functional modes;

extracting a common clock distribution topology from the clock tree, the topology accounting for substantially all of modes and clock-dividing paths of the topology;

15 determining one or more clock paths to be balanced, each comprising a multi-mode dependant clock path;

analyzing any local clock paths that were left out of the common clock distribution topology;

20 developing a local balancing strategy for the local clock paths that were left out of the common clock distribution topology to determine one or more constraints for substantially balancing the local clock paths;

combining the local balancing strategy with the common clock distribution to form a clock tree synthesis constraint to substantially balance the common clock distribution topology and the local clock paths in a substantially automatic process.

14. The method of Claim 13, wherein determining the one or more clock paths to be balanced comprises:

determining an impact that balancing a particular clock path would have on overall clock tree balance and performance of a device associated with the clock tree;

5 determining whether the determined impact of the particular clock path exceeds a predetermined impact; and

if it is determined that the determined impact of balancing the particular clock path exceeds the predetermined impact, determining that the particular clock path should be balanced.

10

15. The method of Claim 14, wherein determining an impact that balancing the particular clock path would have on the overall clock tree comprises:

determining whether the particular clock path operates asynchronously to other portions of the clock tree; and

15 if so, concluding that the impact of balancing the particular clock path does not exceed the predetermined impact.

20 16. The method of Claim 13, further comprising inserting one or more exclusive-NOR (XNOR) gates throughout the clock tree to balance one or more portions of the clock tree, each XNOR gate operable to:

receive an input clock signal on an input clock path;

receive a test mode signal on a test mode path; and

25 generate an output clock signal on an output clock path based on an XNOR operation, a delay from the input clock path to the output clock path being independent of a delay from the test mode path to the output clock path.

17. The method of Claim 16, wherein when the test mode signal received on the test mode path asserts test mode, the output clock signal generated by the XNOR gate comprises a non-inverted output clock signal.

30

18. A system for balancing one or more clock signals in a clock tree having a multi-mode clock distribution, comprising:

one or more first delay equalizers each associated with at least one of a plurality of clock-gating cells arranged in one or more levels in the clock tree, each first delay equalizer operable to provide a balanced input clock signal to the clock-gating cell such that an output clock signal generated by the clock-gating cell is substantially balanced;

10 one or more second delay equalizers each associated with each of one or more clock-dividing and selection modules in the clock tree, each second delay equalizer operable to substantially balance the one or more clock signals between one or more functional modes;

the first and second delay equalizers substantially balancing the one or more clock signals in the clock tree.

15 19. The system of Claim 18, further comprising one or more exclusive-NOR (XNOR) gates inserted throughout the clock tree to balance one or more portions of the clock tree, each XNOR gate operable to:

receive an input clock signal on an input clock path;  
receive a test mode signal on a test mode path; and

20 generate an output clock signal on an output clock path based on an XNOR operation, a delay from the input clock path to the output clock path being independent of a delay from the test mode path to the output clock path.

25 20. The system of Claim 19, wherein when the test mode signal received on the test mode path asserts test mode, the output clock signal generated by the XNOR gate comprises a non-inverted output clock signal.